java - 执行后台任务——替代 AsyncTask?
全部标签 我正在为一个学校项目编写一个ruby引导脚本,这个引导过程的一部分是启动几个后台进程(已编写并正常运行)。我想做的是:`/path/to/daemon1&``/path/to/daemon2&``/path/to/daemon3&`但是,这会在第一次调用执行daemon1时阻塞。我看到了对Process.spawn方法的引用,但这似乎是1.9+的功能,我仅限于Ruby1.8。我也尝试过从不同的线程执行这些守护进程,但我希望我的引导脚本能够退出。那么我怎样才能启动这些后台进程,以便我的引导脚本不会阻塞并可以退出(但仍然有守护进程在后台运行)? 最佳答案
我知道您可以通过键入查看所有可能的佣金任务rake-T但我需要知道任务的具体作用。从输出中,如何找到实际具有任务的源文件?例如,我正在尝试查找db:schema:dump任务的源。 最佳答案 我知道这是一个老问题,但无论如何:rake-W这是在rake0.9.0中引入的。http://rake.rubyforge.org/doc/release_notes/rake-0_9_0_rdoc.htmlSupportforthe–where(-W)flagforshowingwhereataskisdefined.
在编写Rspec测试时,我经常对should_receive感到沮丧。我想知道是否有侵入性较小的替代方案。例如:describe"makingacake"doit"shouldusesomeothermethods"do@baker.should_receive(:make_batter)@baker.make_cakeendend对should_receive的调用是一个很好的描述,但它破坏了我的代码,因为should_receive通过屏蔽原始方法来工作,而make_cake除非make_batter实际上返回一些面糊,否则无法继续。所以我把它改成这样:@baker.should_
我有这个小佣金任务:namespace:dbdonamespace:testdotask:resetdoENV['RAILS_ENV']="test"Rake::Task['db:drop'].invokeRake::Task['db:create'].invokeRake::Task['db:migrate'].invokeendendend现在,当我执行时,它将忽略我尝试硬编码的RAILS_ENV。我如何使这个任务按预期工作 最佳答案 对于这个特定的任务,您只需要更改数据库连接,正如Adam指出的那样,您可以这样做:namesp
假设我有一个这样的rakefile:file'file1'=>some_dependenciesdosh'externaltoolIdonothavecontrolover,whichsometimesfailtocreatethefile'???endtask:default=>'file1'doputs"everything'sOK"end现在,如果我不放置任何内容来代替???,即使外部工具无法生成文件,我也会收到OK消息。什么是通知rake的正确方法,'file1'任务失败了,它应该中止(希望呈现一个有意义的消息——比如哪个任务失败了)——我现在唯一能想到的就是在那里引发异常,但
目前,我有一个像这样的sidekiq工作:classSyncUserincludeSidekiq::Workerdefperform(user_id)#dostuffendend我正在像这样在队列中放置一个作业:SyncUser.perform_asyncuser.id当然这一切都有效,但在调用perform_async和作业实际执行之间有一点延迟。我还能做些什么来告诉sidekiq立即执行作业吗? 最佳答案 这里有两个问题。如果你想立即执行一个作业,在当前上下文中你可以使用:SyncUser.new.perform(user.id
我将收割机线放入rake任务中,以杀死一些额外生成的ruby任务,因为它们有时会不知何故爬上来。system"psaux|grep'namespace:taskname'|grepruby|grep-vgrep|awk'{print$2}'|xargskill-9;echo'Reapedoldnamespace:tasknameprocesses.'"我想在其中添加grep-v$PID_OF_CURRENT_TASK以确保我不会终止当前正在运行的任务。我如何获得该PID? 最佳答案 您可以使用Process.pid在Ruby中获
我有一个Rake任务将配置数据从文件加载到数据库中,是否有正确的ruby/rails方法在迁移时调用它?我的目标是同步我的团队数据库配置,无需广播然后运行任务lalaladefself.upchange_table:fis_situacao_fiscaldo|t|t.remove:mostrar_enderecot.rename:serie,:modeloendFaturamento::Cfop.destroy_all()#performrakehere!end更新我现在的工作方式和工作方式:system('rakesistema:load_datafile=faturamento
所以我有一个包含不同代码示例(阅读片段)的数据库。代码示例由用户创建。在Rails中有没有办法执行它?例如,我的数据库中有以下代码(id=123):return@var.reverse有没有办法让我执行它?像这样的东西:@var='Hello'@result=exec(CodeSample.find(123))所以结果会是'olleH' 最佳答案 您可以使用eval:code='@var.reverse'@var='Hello'@result=eval(code)#=>"olleH"但是这样做要非常小心;您授予该代码对您系统的完全访
我试图理解Ruby中的异常,但我有点困惑。我正在使用的教程说,如果发生与救援语句识别的任何异常都不匹配的异常,您可以使用“else”来捕获它:begin#-rescueOneTypeOfException#-rescueAnotherTypeOfException#-else#Otherexceptionsensure#Alwayswillbeexecutedend但是,我也看到在教程后面的“rescue”中没有指定异常就被使用了:beginfile=open("/unexistant_file")iffileputs"Fileopenedsuccessfully"endrescuef